<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <script>



        var arr = [];
        // for (var i = 0; i < 10; i++) {
        //     arr.push(function () {
        //         return i;
        //     })
        //     console.log(arr[i]());  // 0-9
        // }
        var i = 0;
        arr.push(function () {
            return i;
        })
        console.log(arr[i]());

        i++;
        arr.push(function () {
            return i;
        })
        console.log(arr[i]());

        i++;
        arr.push(function () {
            return i;
        })
        console.log(arr);

        i = 10

        arr.forEach(function (v) {
            console.log(v());   // 10
        })



        var arr = [1, 2, 3, 4];

        // for (var i = 0; i < arr.length; i++) {
        //     console.log(i);
        //     setTimeout(function () {
        //         console.log(i);
        //     })
        // }


        // forEach的回调函数其实是执行了多次的
        // 回调函数的参数i也是局部变量
        //  cb(arr[0],0)
        //  cb(arr[1],1)
        //  cb(arr[2],2)
        //  cb(arr[3],3)

        arr.forEach(function (v, i) {
            // console.log(i);
            setTimeout(function () {
                console.log(i);   // 0-3
            })
        })








        // function myForEach(arr, cb) {
        //     // for(var i = 0 ; i < arr.length ; i++) {
        //     //     cb(arr[i] , i) ;
        //     // }

        //     function cb(v, i) {
        //         // console.log(i);
        //         setTimeout(function () {
        //             console.log(i);
        //         })
        //     }

        //     cb(arr[0], 0);
        //     cb(arr[1], 1);
        //     cb(arr[2], 2);
        //     cb(arr[3], 3);
        // }


    </script>

</body>

</html>